package com.school.sports.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.school.sports.entity.CertificateTemplate;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 证书模板表 Mapper接口
 */
@Mapper
public interface CertificateTemplateMapper extends BaseMapper<CertificateTemplate> {

    /**
     * 分页查询证书模板（带创建用户名）
     * @param page 分页对象
     * @param template 查询条件
     * @return 分页结果
     */
    IPage<CertificateTemplate> selectTemplatePageWithUserName(Page<CertificateTemplate> page, @Param("template") CertificateTemplate template);

    /**
     * 根据模板类型查询模板列表
     * @param templateType 模板类型
     * @param status 模板状态
     * @return 模板列表
     */
    List<CertificateTemplate> selectByTypeAndStatus(@Param("templateType") String templateType, @Param("status") String status);

    /**
     * 根据模板类型查询默认模板
     * @param templateType 模板类型
     * @return 默认模板
     */
    CertificateTemplate selectDefaultTemplateByType(@Param("templateType") String templateType);

    /**
     * 查询活跃模板列表
     * @return 活跃模板列表
     */
    List<CertificateTemplate> selectActiveTemplates();
}